brew (Homebrew) 自身をアップデートするためにはどうしたらいいか

結論

$ brew update

実例

$ brew --version
Homebrew 4.0.24-26-g8d9aa90

$ brew update
==> Downloading https://ghcr.io/v2/homebrew/portable-ruby/portable-ruby/blobs/sha256:f7be167f7ac4f296b9f4c5874ceeea4aafd9999c3c7f2b0378cae7dd273e2322
######################################################################## 100.0%
==> Pouring portable-ruby-3.1.4.x86_64_linux.bottle.tar.gz
==> Homebrew collects anonymous analytics.
Read the analytics documentation (and how to opt-out) here:
  https://docs.brew.sh/Analytics
No analytics have been recorded yet (nor will be during this `brew` run).

==> Downloading https://formulae.brew.sh/api/formula_tap_migrations.jws.json
################################################################################################################# 100.0%
Updated 4 taps (dart-lang/dart, leoafarias/fvm, homebrew/core and homebrew/cask).
==> New Formulae
(中略)
You have 1 outdated formula installed.
You can upgrade it with brew upgrade
or list it with brew outdated.
==> Downloading https://formulae.brew.sh/api/cask_tap_migrations.jws.json
################################################################################################################# 100.0%

$ brew --version
Homebrew 4.2.20

公式ドキュメント

docs.brew.sh

Rails 7.1.3.2(というか ActiveRecord 7.1.3.2)では SQLite gem の v2 のインストールでエラーが発生する

状況

Renovate が自動で出してきた Pull Request で CI が落ちていたので、ログを見たところ、以下のエラーが発生していました*1

bin/rails aborted!
LoadError: Error loading the 'sqlite3' Active Record adapter. Missing a gem it depends on? can't activate sqlite3 (~> 1.4), already activated sqlite3-2.0.1-x86_64-linux-gnu. Make sure all dependencies are added to Gemfile. (LoadError)

結論

github.com

どうすればいいか

上記がマージされたバージョンのリリースを待ちます。すでにリリースされているかもしれません。

補足

以下のような話も出てきています。

github.com

*1:bin/rails db:create 時

Ubuntu にて rbenv で 3.3.1 のインストールでエラーがでたので --with-baseruby で対処した

状況

現状の Ruby が 3.3.0 の状況において $ rbenv install 3.3.1 を実行するとエラーが出て、以下のようなログが出ました。

1727 make[2]: ディレクトリ '/tmp/ruby-build.20240424104050.96605.DfIbDe/ruby-3.3.1/ext/ripper' から出ます
1728 make[2]: ディレクトリ '/tmp/ruby-build.20240424104050.96605.DfIbDe/ruby-3.3.1' に入ります
1729 tool/file2lastrev.rb:6:in `require': cannot load such file -- optparse (LoadError)
1730 »-from tool/file2lastrev.rb:6:in `<main>'
1731 ./tool/file2lastrev.rb:6:in `require': cannot load such file -- optparse (LoadError)
1732 »-from ./tool/file2lastrev.rb:6:in `<main>'
1733 make[2]: *** [uncommon.mk:1322: .revision.time] エラー 1
1734 make[2]: ディレクトリ '/tmp/ruby-build.20240424104050.96605.DfIbDe/ruby-3.3.1' から出ます
1735 make[1]: *** [exts.mk:99: ruby] エラー 2
1736 make[1]: ディレクトリ '/tmp/ruby-build.20240424104050.96605.DfIbDe/ruby-3.3.1' から出ます
1737 make: *** [uncommon.mk:397: build-ext] エラー 2
1738 external command failed with status 2

どうしたか

環境変数 RUBY_CONFIGURE_OPTS="--with-baseruby=$HOME/.rbenv/versions/3.2.3/bin/ruby" を付与して実行したところ、インストールが正常に終了しました。3.2.3 というのは適当に入れた値です*1

$ RUBY_CONFIGURE_OPTS="--with-baseruby=$HOME/.rbenv/versions/3.2.3/bin/ruby" rbenv install 3.3.1
==> Downloading ruby-3.3.1.tar.gz...
-> curl -q -fL -o ruby-3.3.1.tar.gz https://cache.ruby-lang.org/pub/ruby/3.3/ruby-3.3.1.tar.gz
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100 21.0M  100 21.0M    0     0  30.5M      0 --:--:-- --:--:-- --:--:-- 30.5M
==> Installing ruby-3.3.1...
-> ./configure "--prefix=$HOME/.rbenv/versions/3.3.1" --enable-shared --with-ext=openssl,psych,+ "--with-baseruby=$HOME/.rbenv/versions/3.2.3/bin/ruby"
-> make -j 20
-> make install
==> Installed ruby-3.3.1 to /home/foobar/.rbenv/versions/3.3.1

参考的なもの

github.com

*1:もちろん、あらかじめインストールされている必要があります

GA4 の API にて カスタムイベント の値を取得する場合には

結論

以下の画像における「ユーザープロパティ / パラメータ」の値を用います。「ディメンション名」ではないです*1

gyazo.com

たとえば、

  • 「ディメンション名」が hoge であり、
  • 「ユーザープロパティ / パラメータ」の値が fuga の場合

は、API のリクエストにおけるディメンション名は customEvent:fuga になります。

*1:ただし「探索」におけるディメンション名は「ディメンション名」になる

Powered by はてなブログ